<?php

declare(strict_types=1);

/**
 * NOTICE OF LICENSE.
 *
 * UNIT3D Community Edition is open-sourced software licensed under the GNU Affero General Public License v3.0
 * The details is bundled with this project in the file LICENSE.txt.
 *
 * @project    UNIT3D Community Edition
 *
 * @author     HDVinnie <hdinnovations@protonmail.com>
 * @license    https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0
 */

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;

return new class () extends Migration {
    public function up(): void
    {
        DB::table('password_resets as p1')
            ->join('password_resets as p2', function ($join): void {
                $join->on('p1.token', '<', 'p2.token')
                    ->whereColumn('p1.email', '=', 'p2.email');
            })
            ->delete();

        Schema::table('password_resets', function (Blueprint $table): void {
            $table->string('email')->primary()->change();
        });

        Schema::table('sessions', function (Blueprint $table): void {
            $table->string('id')->primary()->change();
        });
    }
};
